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BACKGROUND OF THE INVENTION 



1. Technical Field: 

The present invention is directed to a system 
5 management software utility. More specifically, the 
present invention is directed to an apparatus and method 
of executing a command only once across a heterogeneous 
environment . 



10 2. Description of Related Art: 

In today' s environment a network may consist of 
different computer systems running under different 
operating systems and using different software management 
utilities. The network is usually managed by a system 

15 administrator, A system administrator is an individual 
that is responsible for maintaining a computer system or 
a network of systems. The system administrator typically 
adds and configures new computer systems, sets up user 
accounts, installs system-wide software, allocates mass 

20 storage space etc. In short, the system administrator 
ensures that the network is operational and is running at 
its optimum. 

To perform this task, the system administrator 
periodically runs tests and executes management commands 
25 on the various systems in the network. When doing so, 
the system manager has to access each management software 
utility and run as many commands as there are system 
management utilities in use in the network. 

Thus, what is needed is a method and apparatus that 
30 allow one system management command to run on the 
different computers in the network. 



- 2 - 



Docket No. AUS920010904US1 

SUMMARY OF THE INVENTION 

The present invention provides an apparatus, method, 
5 system and computer program product for allowing a 
command to be entered once and be translated into 
different command structures and be executed by computer 
systems running under different operating systems and 
having different command structures. The command is 

10 entered into a common interface. The common interface 
translates the command into the different command 
structures and dispatches the command to the computer 
systems for execution. The common interface also 
requests that command execution progress status be 

15 provided by the computer systems. 



20 BRIEF DESCRIPTION OF THE DRAWINGS 

The novel features believed characteristic of the 
invention are set forth in the appended claims. The 
invention itself, however, as well as a preferred mode of 

25 use, further objectives and advantages thereof, will best 
be understood by reference to the following detailed 
description of an illustrative embodiment when read in 
conjunction with the accompanying drawings, wherein: 

Fig. 1 is an exemplary block diagram illustrating a 

30 distributed data processing system according to the 
present invention. 
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Fig. 2 is an exemplary block diagram of a server 
apparatus according to the present invention. 

Fig. 3 is an exemplary block diagram of a client 
apparatus according to the present invention. 

Fig. 4 is a conceptual view of a software engine 
used in the present invention. 

Fig. 5 depicts a table within which three lists are 
cross-referenced to each other. 

Fig. 6 illustrates a first dialog window of a common 
interface . 

Fig. 7 illustrates a second dialog window of the 
common interface. 

Fig. 8 illustrates a third dialog window of the 
common interface. 

Fig. 9 illustrates a fourth dialog window of the 

common interface . 

Fig. 10 depicts an execution progress dialog. 

Fig. 11 depicts a flow chart of the common interface 

dialog window. 

Fig. 12 is a flow diagram of the command execution 

progress dialog. 

Fig 13 is a flow diagram illustrating the corrective 

action procedure. 

DETAILED DESCRIPTION OF THE PREFERE^D EMBODIMENT 

With reference now to the figures. Fig. 1 depicts a 
pictorial representation of a network of data processing 
systems in which the present invention may be 
implemented. Network data processing system 100 contains 
a network 102, which is the medium used to provide 
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communications links between various devices and 
computers connected together within network data 
processing system 100, Network 102 may include 
connections, such as wire, wireless communication links, 
5 or fiber optic cables . 

In the depicted example, server 104 is connected to 
network 102 along with storage unit 106, In addition, 
clients 108, 110, and 112 are connected to network 102. 
These clients 108, 110, and 112 may be, for example, 
10 personal computers or network computers. In the depicted 
example, server 104 provides data, such as boot files, 
operating system images, and applications to clients 108, 
2 110 and 112. Clients 109, 110, and 112 are clients to 

server 104. Network data processing system 100 may 
15 include additional servers, clients, and other devices 
•^^ not shown. In the depicted example, network data 

Hi processing system 100 is interconnected via the Internet 

■L.. and represents a collection of networks and gateways that 

use the TCP/IP suite of protocols to communicate with one 
20 another. At the heart of the Internet is a backbone of 
13 high-speed data communication lines between major nodes 

'"'^ or host computers, consisting of thousands of commercial, 

government, educational and other computer systems that 
route data and messages. Of course, network data 
25 processing system 100 also may be implemented as a number 
of different types of networks, such as for example, an 
intranet, a local area network (LAN) , or a wide area 
network (WAN) . Additionally, clients 108, 110 and 112 
may be a group or cluster of computers and each cluster 
30 may be running under a different operating system (0/S) 
and having different system management software 
utilities. Thus, Fig. 1 is intended as an example, and 
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not as an architectural limitation for the present 
invention. 

Referring to Fig. 2, a block diagram of a data 
processing system that may be implemented as a server, 
5 such as server 104 or any one of clients 108, 110 and 112 
shown in Fig. 1. Data processing system 200 may be a 
symmetric multiprocessor (SMP) system including a 
plurality of processors 202 and 204 connected to system 
bus 206. Alternatively, a single processor system may be 

10 employed. Also connected to system bus 206 is memory 
controller/cache 208, which provides an interface to 
local memory 209. I/O bus bridge 210 is connected to 
system bus 206 and provides an interface to I/O bus 212. 
Memory controller/cache 208 and I/O bus bridge 210 may be 

15 integrated as depicted. 

Peripheral component interconnect (PCI) bus bridge 
214 connected to I/O bus 212 provides an interface to PCI 
local bus 216. A number of modems may be connected to 
PCI local bus 216. Typical PCI bus implementations will 

20 support four PCI expansion slots or add-in connectors. 
Communications links to network computers 108, 110 and 
112 in Fig. 1 may be provided through modem 218 and 
network adapter 220 connected to PCI local bus 216 
through add-in boards. 

25 Additional PCI bus bridges 222 and 224 provide 

interfaces for additional PCI local buses 226 and 228, 
from which additional modems or network adapters may be 
supported. In this manner, data processing system 200 
allows connections to multiple network computers, A 

30 memory-mapped graphics adapter 230 and hard disk 232 may 
also be connected to I/O bus 212 as depicted, either 
directly or indirectly. 
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Those of ordinary skill in the art will appreciate 
that the hardware depicted in Fig. 2 may vary. For 
example, other peripheral devices, such as optical disk 
drives and the like, also may be used in addition to or 
5 in place of the hardware depicted. The depicted example 
is not meant to imply architectural limitations with 
respect to the present invention. 

The data processing system depicted in Fig. 2 may 
be, for example, an IBM e-Server pSeries system, a 
10 product of International Business Machines Corporation in 
Armonk, New York, running the Advanced Interactive 
Executive (AIX) operating system or LINUX operating 
system. 

With reference now to Fig. 3, a block diagram 

15 illustrating a data processing system is depicted in 
which the present invention may be implemented. Data 
processing system 300 is an example of a client computer. 
Data processing system 300 employs a peripheral component 
interconnect (PCI) local bus architecture. Although the 

20 depicted example employs a PCI bus, other bus 
architectures such as Accelerated Graphics Port (AGP) and 
Industry Standard Architecture (ISA) may be used. 
Processor 302 and main memory 304 are connected to PCI 
local bus 306 through PCI bridge 308. PCI bridge 308 

25 also may include an integrated memory controller and 
cache memory for processor 302. Additional connections 
to PCI local bus 30 6 may be made through direct component 
interconnection or through add-in boards. In the 

depicted example, local area network (LAN) adapter 310, 

30 SCSI host bus adapter 312, and expansion bus interface 
314 are connected to PCI local bus 306 by direct 
component connection. In contrast, audio adapter 316, 
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graphics adapter 318, and audio/video adapter 319 are 
connected to PCI local bus 306 by add-in boards inserted 
into expansion slots. Expansion bus interface 314 
provides a connection for a keyboard and mouse adapter 
5 320, modem 322, and additional memory 324, Small 
computer system interface (SCSI) host bus adapter 312 
provides a connection for hard disk drive 326, tape drive 
328, and CD-ROM drive 330. Typical PCI local bus 
implementations will support three or four PCI expansion 

10 slots or add-in connectors. 

An operating system runs on processor 302 and is 
used to coordinate and provide control of various 
components within data processing system 300 in Fig. 3. 
The operating system may be a commercially available 

15 operating system, such as Windows 2000, which is 
available from Microsoft Corporation. An object oriented 
programming system such as Java may run in conjunction 
with the operating system and provide calls to the 
operating system from Java programs or applications 

20 executing on data processing system 300. ''Java" is a 
trademark of Sun Microsystems, Inc. Instructions for the 
operating system, the object-oriented operating system, 
and applications or programs are located on storage 
devices, such as hard disk drive 326, and may be loaded 

25 into main memory 304 for execution by processor 302. 

Those of ordinary skill in the art will appreciate 
that the hardware in Fig. 3 may vary depending on the 
implementation. Other internal hardware or peripheral 
devices, such as flash ROM (or equivalent nonvolatile 

30 memory) or optical disk drives and the like, may be used 
in addition to or in place of the hardware depicted in 

- 8 - 



Docket No. AUS920010904US1 

Fig. 3. Also^ the processes of the present invention may 
be applied to a multiprocessor data processing system. 

As another example, data processing system 300 may 
be a stand-alone system configured to be bootable without 
5 relying on some type of network communication interface, 
whether or not data processing system 300 comprises some 
type of network communication interface. As a further 
example, data processing system 300 may be a Personal 
Digital Assistant (PDA) device, which is configured with 

10 ROM and/or flash ROM in order to provide non-volatile 
memory for storing operating system files and/or user- 
generated data . 

The depicted example in Fig. 3 and above-described 
examples are not meant to imply architectural 

15 limitations. For example, data processing system 300 
also may be a notebook computer or hand held computer in 
addition to taking the form of a PDA. Data processing 
system 300 also may be a kiosk or a Web appliance. 

The present invention is a software utility that may 

20 reside on a data storage medium such as a floppy disk, 
compact disk (CD) , hard disk etc. of one or all the 
client systems and servers (i.e., all the computer 
systems) of the network. The present software utility is 
a web-based utility (i.e., uses the HTML protocol) and is 

25 used to send out distributed commands to any, a few or 
all the computer systems in the network. Note that, 
although the software utility of the present invention 
uses the HTML protocol, it should be understood that any 
other protocol or combination thereof can be used and 

30 would therefore be well within the scope and spirit of 
the invention. 
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Software Engine 

At the heart of the invention is a software engine 
that interfaces or glues different software management 
utilities to a common interface. Fig. 4 is a conceptual 
5 view of a software engine 400 used in the present 
invention. The software engine 400 interfaces on one 
side (side 410) with a common interface, described below, 
and on the other side (side 420) with the various 
software management utilities used in the network. 

10 In the present example, a Tivoli, Sun Microsystem 

and ''other" software management utilities are shown. The 
other software management utility may be an existing or 
future software management utility. Indeed, the software 
engine 400 may be provided with a set of interface 

15 specifications allowing existing or future software 
management utilities to be plugged into the common 
interface. That is, so long as interface specifications 
of a software management utility are provided, a system 
administrator or programmer may interface or glue the 

20 software management utility to the common interface. 
Consequently, although three software management 
utilities are displayed, the software engine may 
accommodate as many software management utilities as are 
used in a network, including homegrown utilities. 

25 The software engine 400, in essence, translates 

communications between the common interface and the 
various software management utilities. Thus, the 

software engine 400 uses a translation table (not shown) 
to map commands from the common interface into the 

30 various utilities. Using a translation table to 

translate communications between two software devices is 
well known in the field and is thus not explained. The 
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software engine 400 also contains a list of all the 
computer systems in the network and their locations, 
network identifications (IDs) or network addresses as 
well as a list of all the software management utilities 
5 in use in the network. These lists are cross-referenced 
with each other. Fig. 5 depicts a table with such cross- 
referenced lists - 

Data, such as computer system, software management 
utility and network address, is entered into the cross- 

10 referencing table each time a computer system is added to 
the network. Conversely, data may be taken out from the 
table when a computer system is no longer a part of the 
network. The data can be entered manually or 

automatically. For example, a system administrator may 

15 enter into the table or take out from the table the 
proper information each time a computer system is added 
or taken out of the network, respectively. 
Alternatively, each time a new computer system in the 
network requests a network address, it can be asked to 

20 provide information regarding the software management 
utility it is using. This information as well as the 
name of the computer and its network address may then be 
entered automatically into the table. 

The software engine 400 may be configured to 

25 periodically ping the computer systems to check for 
network connectivity or system operability. To ping 
(short for Packet INternet Groper) is to send a packet to 
a target system and wait for a reply. If a reply is not 
forthcoming, then the target system may not be connected 

30 or may not be up and running or may have a problem. If a 
computer fails to respond, its network connectivity 
status may be investigated. 
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Common Interface Dialog Window 

As stated above, the software engine 400 interfaces 
with the coiranon interface. Fig. 6 illustrates a first 
dialog window of the common interface. In Fig. 6 are 
shown general tab 602, options tab 603, hosts tab 604 and 
groups tab 605. These tabs allow a user to navigate 
among different dialog windows of the common interface 
and are therefore common to all the dialog windows. Also 
common to all the dialog windows of the common interface 
are run button 620, save button 622, cancel button 624 
and help button 626. The functions of these buttons will 
be described later. 

The dialog window of the general tab 602 is the 
default window of the common interface. That is, when 
the invention is activated. Fig. 6 is displayed. This 
dialog window is intended to prompt for all necessary 
information needed to issue a command to the network. 
For example, the name of the command should be entered in 
box 606, Browse button 607 is used to display all 
existing commands. A user may therefore enter the name 
of a command manually (i.e., by typing the name in the 
box) or automatically (i.e., by double-clicking on the 
name of a command in the displayed list of commands) . 
The directory where the command is stored should be 
entered in path box 609 and the command itself (i.e., 
script to be run) in command box 610. Box 610 may be 
maximized to allow the user to scrutinize the script. 
The identity of the user executing the command is to be 
entered in box 612 and a brief description of the command 
in box 614. 
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When a user enters the name of an existing command 
in box 606, the directory where the command is stored, 
the command script and the brief description of the 
command will all be entered automatically in boxes 609, 
5 610 and 614, respectively, as soon as the cursor leaves 
command box 606, Note that, whether a command is 
executed depends on the identity of the user. For 
example, a user such as a system administrator may be 
able to run all commands whereas other users may only be 

10 able to run commands for which they have authorization. 
Authorization may be given by the system administrator. 

The computer system or systems on which a command is 
to be executed should be entered in host names box 616. 
Browse button 617 may be used to display a list of all 

15 existing computer systems in the network. This list can 
be taken from the table in Fig. 5. 

The computer systems on which a command is to be 
executed may be organized in groups. The dialog window 
of groups tab 604, which will be described later, allows 

20 for the grouping of the computer systems. Entering a 
group or groups of computer systems in groups hosts box 

618 is an alternative method of specifying on which 
computers the command is to be executed. Browse button 

619 allows a user to choose from among existing groups of 
25 hosts. As with all the other browse buttons, names of 

existing groups of hosts may be entered automatically by 
double-clicking on particular names from the displayed 
list . 

When options tab 603 is selected, the dialog window 
30 shown in Fig. 7 is displayed. In Fig. 7, a user may 
select the number of computer systems on which the 
command is to be concurrently executed. The user may 
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select the number of computer systems by using slider 710 
or by entering the number in box 720. In this particular 
example, up to 64 computer systems may be selected. If a 
number greater than 64 is entered in box 720, an error 
message may be generated. The error message may be a 
warning that the number has to be between 1 and 64, 
inclusively. Note that although in this particular 
example the number of computer systems on which a command 
is to be concurrently executed is restricted to 64, it is 
obvious that the present invention may be designed to use 
an infinite number. Thus, numbers greater than 64 are 
perfectly within the scope of the invention. 

The user may choose to have the invention ascertain 
that the computer systems are up and operating before the 
execution of the command by checking box 730, When box 
730 is checked, the invention pings the computer systems 
on which the command is to be executed. Any computer 
systems that do not respond to the ping may be taken off 
the list to reduce the number of execution errors. 

The user may also select whether the output of the 
execution is to be streamed or provided all at once by 
checking box 740. If this box is not checked, the result 
of the execution of the command will be displayed after 
it (the execution) has completed. In addition, the user 
may choose among a plurality of security shells to use. 
Security shells provided are the remote shell (RSH) and 
the secure shell (SSH) . However, any other security 
shells or measures may be used and would therefore be 
within the scope of the invention. 

Fig. 8 displays a dialog window of the hosts tab 604 
of the common interface. This dialog window lets a user 
add computer systems to the list of computer systems on 
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which the command is to be executed. This dialog window 
is provided as a convenience to the user since the 
computer systems can easily be entered in box 616 of Fig. 
6, The computer systems on which the command is to be 
5 executed may be added using box 810 and add button 820. 
The selected computer systems and the software management 
utility running on the systems are displayed in box 840, 
The software management utility information may be taken 
from Fig. 5. The remove button 830 is used in 
10 conjunction with box 810 to remove computer systems from 
the list of systems on which the command is to be 
executed. 

Fig. 9 is a dialog window of the groups tab 605 of 
a the common interface. In this window, a user may 

15 organize the computer systems in groups. A group is 
formed by entering a group name in group name box 905 and 
by adding computer systems to the group using host names 
box 915 and add button 925. Any computer system may be 
S taken out of a group by using host names box 915 and 

20 remove button 930. When a group is complete, it is saved 
Q using the save group button 935. Groups can also be 

^ formed using the copy group button 940. In this case, 

two or more existing groups may be combined together. An 
existing group may be deleted by entering the name of the 
25 group in group name box 905 and clicking on delete group 
box 945. Browse button 910 is used to list the names of 
all existing groups. 

Returning to Fig. 6, when all relevant information 
has been entered, the command may be run using run button 
30 620. Note that run button 620 will be disabled unless 
the command specification box is filled in (i.e., path 
window 609 and command window 610 are filled in) . In 
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addition, the run button 620 will be disabled when user 
window 612 and host names window 616 or groups of hosts 
window 618 are not filled in. 

Save button 622 is used to store a cominand and its 
information (i.e., command name, directory in which 
stored, command script and brief description) . Cancel 
button 624 is used to dismiss the common interface 
without performing any action and help button 62 6 is used 
to describe how each button and box of the different 
dialog windows are to be used. 

Once run button 620 is clicked on, the software 
engine will dispatch the command using the appropriate 
translations to the computer systems. If TCP/IP 

(Transmission Control Protocol/Internet Protocol) is 
used, the software engine will dispatch the command to a 
listening port (i.e., port 80) of the systems. There, an 
application program will take the command to the 
processor or processors of the computer systems for 
execution. Obviously, other protocols such as the UDP 
(User Datagram Protocol), HTTP (Hyper Text Transfer 
Protocol) protocol etc. may be used as well. Thus, the 
invention is not limited to the TCP/IP protocol. 

Execution Progress Dialog Window 

The command dispatched to the computer systems may 
contain another command requesting that the computer 
systems continually provide execution status back to the 
software engine. Alternatively, status requests will be 
periodically sent to the systems. Thus, as soon as the 
command is sent execution status will be provided back to 
the software engine. The software engine will display 
the status in a window. The window used, in this 
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particular example, is an execution progress dialog 
window. Fig. 10 is a particular example of the execution 
progress dialog. The execution progress dialog is made 
of two parts, an execution progress window 1000 and an 
output display window 1050. In the execution progress 
window 1000, the name of the command being executed and 
its specification are displayed. 

The execution progress window 1000 also contains a 
^'waiting'' sub-window 1005, a "working'' sub-window 1010 
and a ''completed'' sub-window 1025. The completed sub- 
window 1025 is further subdivided into ''successful" sub- 
window 1015 and ''failed" sub-window 1020. In the 
"waiting" sub-window 1005, the names and the number of 
all the computer systems on which the command has yet to 
start executing are displayed. 

In the "working" sub-window 1010, the names and the 
number of the computer systems on which the command is 
being executed are displayed. When the command begins 
execution on a computer system, the name of the computer 
system is moved from the "waiting" sub-window 1005 to the 
"working" sub-window 1010. The number displayed in 
"waiting" sub-window 1005 is decreased by one and the 
number displayed in the "working" sub-window 1010 is 
increased by one. 

When the command has finished executing on a 
computer system, the name of the computer system will be 
moved from the "working" sub-window 1010 to the 
"completed" sub-window 1025 and displayed in either the 
"successful" sub-window 1015, if it has been successfully 
completed, or the "failed" sub-window 1020 if it has not 
successfully completed. The number shown in working 
window 1010 will be decreased by one and the number in 
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either the "successful' sub-window 1015 or the "failed" 
sub-window 1020 will be increased by one. 

If the user highlights the name of a computer system 
in any one of the sub-windows, further information 
5 regarding the execution status of the command will be 
displayed in the output window 1050. For example, if the 
name of the highlighted computer system is in the 
"waiting" sub-window 1005, "waiting to execute" will be 
displayed in the output window 1050. If the name of the 
10 highlighted computer system is in the "working" sub- 
window 1010, the execution progress of the command will 
be displayed in real-time. If the name of the 
highlighted computer is in the "successful" window 1015, 
the result of the command will be displayed. For 
15 example, if the command was to list all files in a 
directory, then all the files found in the directory will 
be displayed. If, on the other hand, the execution of 
the command should not return a result, then "command 
completed successfully" will be displayed. 
20 If the name of the computer system is in the 

"failed" sub-window 1020, the reason for the failure will 
be displayed. Note that the names of the computers in 
the "failed" sub-window may be displayed in red to alert 
the system administrator. 
25 In addition to the table cross-referencing the lists 

of the names of the computer systems, their network 
addresses and the software management utilities, the 
software engine 400 may also have a rules table cross- 
referencing error messages with error types. When a 
30 computer fails to complete the execution of the command 
successfully, armed with the error message from the 
computer system in the "failed" sub-window, the software 
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engine may access the rules table to determine the type 
of error responsible for the unsuccessful completion of 
the command. If the error is of a correctable nature, 
the user may be prompted as to whether corrective action 
5 should ensue. If the user elects to correct the error, 
the software engine will do so automatically. After the 
error has been corrected, the user will be prompted as to 
whether the command should be re-executed by the computer 
system. If so, the software engine will dispatch the 

10 command to the computer system. Otherwise, nothing will 
be done. If the error is not of a correctable nature, 
then only the reason for the error will be displayed. 
Fig 13 is a flow diagram illustrating the corrective 
action procedure. The process is entered once a ''failed'' 

15 state is entered by one of the computer systems (step 
1300) . If the error that causes the failure is of a 
correctable nature, the process will prompt the user as 
to whether the error is to be corrected. If so, the 
error will be corrected (steps 1310, 1320 and 1330). An 

20 example of an error that is correctable is if, for 
instance, the command was for a new software package to 
be installed on the computer systems and one computer 
system simply did not have anymore available memory 
space. If the user indicates that the error should be 

25 corrected, then the software engine coula send a command 
to allocate more memory space. 

If the error is not of a correctable nature or if 
the error is correctable but the user does not care to 
fix the error, then nothing will occur (steps 1310, 1315, 

30 1320 and 1325) . 

After correcting the error, the user will be 
prompted as to whether the command is to be re-executed 
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by the computer system (that failed the command) . If so, 
the command will be re-executed by the computer system as 
outlined in Fig. 12 below (steps 1340 and 1350). If not, 
the process will stop there (steps 1340 and 1345) . 
5 Returning to Fig. 10, the execution of the command 

on any computer system may be canceled, if the name of 
the computer system is highlighted while it is in the 
''waiting'' sub-window 1005 and the stop button 1060 is 
selected. When this occurs, a window will pop open 

10 requesting the user to confirm the cancellation action. 
If the user does so confirm, the name of the computer 
system will be taken off the ''waiting'' sub-window. If 
the name of the highlighted computer system is instead in 
the "working" sub-window 1110 when the stop button 1050 

15 is asserted, again a window will pop open requesting that 
the user confirm the cancellation action. If the user 
does so confirm, the execution of the command will be 
stopped and the name of the computer system will be moved 
to the "failed" sub-window. To stop the execution of the 

20 command, the software engine sends a stop command to that 
system. In this case, the reason for the failure may be 
displayed as "command canceled by user". 

Close button 1055 is used to close the execution 
progress dialog window without disturbing the execution 

25 of the command on the computer systems. As its name 
suggests, hide output button 1065 is used to hide the 
output window 1050 from view. When the output window is 
hidden from view, the output button 1065 is changed to 
show output button 1065 (not shown) . This is to let the 

30 user know that the button is to be selected if the output 
window 1050 is to be displayed. Help button 1070 
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provides information about every option on the execution 
progress window dialog. 

Instead of displaying the output of the command in 
the execution progress dialog, a user may choose to have 
5 it presented in graphical representations such as charts, 
graphs etc. The output may also be saved in HTML, 
Poscript, XML, etc. The output may be e-mailed, for 
example, to the system administrator or posted on the web 
for easy accessibility. 

10 Fig. 11 is a flow chart of the common interface 

dialog window. This flow chart will be better understood 
when viewed in conjunction with Fig. 6. When the common 
interface is accessed, the process is at step 1100. At 
step 1105, the name of a command is entered in name box 

15 606. If the command already exists, the directory where 
the command is stored, the command script and the 
definition of the command are provided in path box 609, 
command box 610 and description box 614, respectively, as 
soon as the cursor leaves name box 606 (steps 1110 and 

20 1115) . Note that the name of the command will exist if 
entered by double-clicking on a name from the list of 
existing commands displayed when the browse button 607 is 
used. If the command is not an existing command, the 
user needs to enter the information in the boxes (step 

25 1120) . 

The name or names of the computer systems or 
existing group or groups of computer systems on which the 
command is to be executed are to be entered in hosts 
names box 616 or groups host names 618 (step 1125) . If a 
30 computer system is not in the list in Fig. 5, the user 
will be prompted to supply the network address and the 
software management utility running on the computer 
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system (steps 1130 and 1135). At this point, a check is 
made to determine whether the software engine is able to 
translate commands from the common interface into the 
software management utility in use on that computer 
5 system. If yes, Fig. 5 is updated (steps 1140 and 1150). 
If no, an error message is generated (steps 1140 and 
1145) . The error message may be ''error software 

management running on the particular host is unknown''. 
Note that the software management can determine whether 
10 it can translate commands by consulting the table in Fig. 
5. 

If all the computer systems on which the command is 
to be executed are in the list in Fig. 5, then the 
identity of the user needs to be entered in box 612 (step 

15 1155) , If the user has proper authorization to run the 
command on the systems, the user will be allowed to click 
on the run button 620 to start execution of the command 
(steps 1160 and 1170). If not, the user may save out of 
the system to secure the proper authorization (step 

20 1165) . Note again that at any time in the process, a 
user may save, cancel or request help by clicking on 
buttons 622, 624 or 626, respectively. 

Fig. 12 is a flow diagram of the command execution 
progress dialog window. The diagram will be better 

25 understood if viewed in conjunction with Fig. 10. 
Further, in order not to obfuscate the invention, the 
process is using only one computer system. It should be 
understood, therefore, that the process will be traversed 
as many times as there are computer systems in the 

30 network running the command. 

In any event, once the run button 620 in Fig. 6 is 
asserted, the process starts (step 1200). At step 1205, 
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the name of the computer system is displayed in the 
''waif' sub-window 1005. While the name of the computer 
system is displayed in the "waif' sub-window, three 
checks are continuously being made. The first check is 
5 to determine whether the name of the computer system is 
selected for a command execution status display. If so, 
''waiting to be executed'' will be displayed in output 
window 1050 (steps 1220 and 1225) . 

The second check is to determine whether to cancel 

10 the execution of the command. If so, the command 
execution will be canceled (steps 1210 and 1215). As 
stated earlier, the command execution will be canceled 
when the user selects the name of the computer system in 
the "wait" sub-window and clicks on the stop button 1060. 

15 When the stop button 1060 is asserted, the software 
engine in Fig. 4 sends a kill execution command to the 
selected computer system. 

The third check is to determine whether the computer 
system has started executing the command. If so, the 

2 0 name of the computer system is moved from the "wait" sub- 
window to the "working" sub-window (steps 1230 and 1235) . 

While the computer system is displayed in the 
"working" sub-window, three checks are again continuously 
made. The first check is to determine whether the 

25 computer system has been selected to provide execution 
status. If so, the software engine sends a request to 
the computer system to provide real-time progress of the 
execution of the command. The progress is displayed in 
the output window 1050 (steps 1220 and 1225) . 

30 The second check is made to determine whether the 

execution of the command is to be stopped. If so, the 
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software engine sends a kill execution comnand to the 
computer system (steps 1210 and 1215) . 

The third check is made to determine whether the 
command has finished executing on the computer system. 
5 If so, another check is made to determine whether the 
execution was successful. If yes, the name of the 
computer system is moved from the ''working'' sub-window to 
the ''successful'' sub-window (steps 1240, 1245 and 1250). 
If the execution is not successfully completed, the name 

10 of the computer system is instead moved to the "failed" 
sub-window (steps 1240, 1245 and 1255) . 

While the name of the computer system is in either 
the "successful" or the "failed" sub-window, a check is 
continuously made to determine whether command execution 

15 status is to be provided. If so, and if the computer 
system is in the "successful" sub-window, either the 
result of the command or a "command successfully 
completed" is displayed in the output window 1050 (steps 
1220 and 1225) . If the computer system is instead 

20 displayed in the "failed" sub-window, the software engine 
will send a request to the computer system to provide the 
reason why the execution of the command failed. The 
reason is then displayed in the output window 1050 (steps 
1220 and 1225) . 

25 As mentioned above, the user may then be prompted to 

have the error automatically corrected by the invention 
if the error is of a correctable nature. If the user so 
elects, the invention will correct the error and prompt 
the user to run the command again (see Fig. 13) . 

30 The description of the present invention has been 

presented for purposes of illustration and description, 
and is not intended to be exhaustive or limited to the 
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invention in the form disclosed. Many modifications and 
variations will be apparent to those of ordinary skill in 
the art. The embodiment was chosen and described in 
order to best explain the principles of the invention, 
the practical application, and to enable others of 
ordinary skill in the art to understand the invention for 
various embodiments with various modifications as are 
suited to the particular use contemplated. 



